TITLE OF THE INVENTION 

TRACEABLE METHOD AND SYSTEM FOR ENCRYPTING AND/OR DECRYPTING 
DATA, AND RECORDING MEDIA FOR IMPLEMENTING THE METHOD 

5 

CROSS-REFERENCE TO RELATED APPLICATIONS. 

STATEMENT REGARDING FEDERALLY SPONSORED RESEARCH OR 
DEVELOPMENT. 

None. 

THE NAMES OF THE PARTIES TO A JOINT RESEARCH AGREEMENT. 
None. 

INCORPORATION-BY-REFERENCE OF MATERIAL SUBMITTED ON A COMPACT 
DISC. 

None. 

BACKGROUND OF THE INVENTION. 

Field of the Invention. 

The invention pertains to a traceable method and system for encrypting and/or 
20 decrypting broadcast data, and to recording media for implementing the method. 
More precisely, the invention concerns a traceable method in v^^hich: 

- when encrypting broadcast data, the transmitter applies at least one first secret 

cryptographic function, and 

- when decrypting said broadcast data, all the decoders apply at least one same second 
25 secret cryptographic function identical to said first function or its inverse, each decoder for 

this purpose using a mathematical description of said second function recorded in a memory. 

Traceable encrypting methods are methods in which a method for tracing traitors may 
be implemented. 
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Description of Related Art 

Traitor tracing methods are used to fight against the pirating of services which, on a 

broadcast channel, distribute encrypted multimedia contents such as video, television, 

images, music, texts, Web pages, electronic books, programmes etc. The purpose of traitor 
5 tracing methods is to prevent one or more lawful users of said services from re-distributing 

data deduced from the secret keys and decryption algorithms implanted in their decrypting 

equipment so as to enable unlawful users (pirates) to have in-clear access to said content. 

These methods guarantee that if such a fraud should occur, the identity of at least one of the 

lawful users at the source of the fraud may be reconstituted by the service operator 
10 distributing the content, or more generally by an authority, on the basis of data re-distributed 

to unlawful users. The lawful user at the source of the fraud is called a "traitor" in the 

remainder of the description. 

The notion of tracing traitors was proposed for the first time by Benny Chor, Amos 

Fiat and Moni Naor in their 1994 article: "Tracing Traitors, Advances in Cryptology" - 
15 Crypto'94, Lecture Notes in Computer Science, vol. 839, Springer- Verlag, 1994, pp. 257- 

270. In this article, the first tracing techniques in a cryptographic system are put forward. 

The cryptographic systems in which a traitor tracing method may be implemented are called 

"traceable". Almost all these techniques are of combinatory nature. In other words, each 

lawful user of the cryptographic system is allotted a sub-set of keys of a set (generally a fairly 
20 large set) of basic keys. This sub-set of basic keys allotted to a user is unique for each user 

and forms the user's own personal key. 

The data broadcast within this system comprises encrypted messages. Each encrypted 

message is formed of a content, encrypted by means of a content-encrypting key, and of 

headers each encrypted with a basic key. Each header contains a value representing part of 
25 the content-encrypting key. 

When users receive one of these messages, they use their sub-set of basic keys to 

decrypt some values contained in the received headers. They then combine these decrypted 

values to reconstitute the content-encrypting key, and this reconstituted content-encrypting 

key is used to decrypt the content of the message. 
30 If one of the lawful users of the system communicates his/her personal key to an 

unlawful user, then in this traceable cryptographic system it is possible to trace the identity of 

the traitor from the personal key used by the unlawful user. 
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However, traitor tracing methods of combinatory nature have the disadvantage of 
requiring the broadcasting of a considerable volume of headers. In particular, the number of 
headers to be broadcast is proportional to the logarithm of the number of lawful users of the 
system, and to other parameters such as the maximum size k of traitor coalitions against 
5 whom protection is sought. By coalition here is meant a group k of traitors who group 
together to combine their personal keys in an attempt to create a new personal key which can 
be used to decrypt the encrypted content, without examination of this new personal key 
disclosing the identity of one of the traitors. 

The invention sets out to remedy this drawback by proposing a new traitor tracing 
10 method which does not require the broadcasting of a large number of headers. 

BRffiF SUMMARY OF THE INVENTION. 

The subject of the invention is therefore a traitor tracing method such as described 
above, characterized in that when implementing the second function, the mathematical 

15 description of this second function to which each decoder has recourse is different from one 
decoder to another or from one group of decoders to another, so that the mathematical 
description to which recourse is made exclusively identifies the particular decoder or group 
of decoders among all the decoders. 

In the above method, it is possible to trace the traitor who communicated the 

20 mathematical description of his/her secret second function to an unlawful user, on the basis 
of analysis of the mathematical description of this second function used by the unlawful user 
to decrypt the transmitted data. Through the construction of each mathematical description in 
the system, said description represents the identity of the traitor. With the combinatory 
methods, on account of the fact that a personal set of keys is used in each decoder, the same 

25 content-encrypting key has to be transmitted several times encrypted in different forms. The 
headers placed at the start of the broadcast content are used for this purpose. Therefore the 
information contained in the headers is extremely redundant and each decoder only processes 
part of the received headers. 

In the inventive method, on account of the fact that traitor identification is no longer 

30 based on the use of personal sets of keys but on use by the transmitter of different 
descriptions of one same cryptographic function, identical to the first cryptographic function, 
or its inverse, it is no longer necessary for at least part of the broadcast data to be redundant. 
Consequently the number of headers needed to broadcast an encrypted message using the 
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above method is lower than the number of headers needed to broadcast the same message 
using a combinatory method. 

According to further characteristics of the method, it is characterized in that: 

- the second cryptographic function is able to process non-redundant data; 

- said mathematical description Fkj recorded in the memory of each decoder is formed 
of several elementary functions Gij which must be composed one after the other in 
determined order to form said second secret function; 

- each elementary function Gij is equal to the composition of at least three functions 
as per one of the following equations: 

Gij = f'i,jOgaj(i)OS 

G2j=f '2,jOg„j(2) Ofi,j 



Gr-l,j = f'r-lj0g„j(r.l)0fr.2o 
Grj=TOg,j(r)OfMo 

in which: 

- Gij is the -th elementary function of decoder j, j being the index identifying a 
decoder or group of decoders, 

- functions fy and f 'y are predefined functions able to render the elementary 
functions Gij non-commutative between each other, 

- Oj is a permutation of all indices {1; ...; rjunique to each decoder or group of 
decoders, 

- goj(t) is the crj(t) -th function of a predefined whole formed of r non-linear predefined 
functions gi commutative between each other, and 

- S and T are predefined functions able to render difficult the cryptanalysis of 
elementary functions Gi j and Grj respectively, 

-1 

- each function f 'i j is equal to the inverse f of function fij, 

- functions fj j are linear functions of a set L^^ of the tuples of elements of a finished 
body L on itself; 

- functions S and are T are invertible; 

- functions S and T are linear functions of a set L"^ of the tuples of elements of a 
finished body L towards itself; 
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- functions gj are chosen so that each elementary function Gy corresponds to an 
encryption block of a multivariate encryption algorithm; 

- each function gi is of the form gi(a) = a''', in which a is an element of an extension L' 
of degree n of a basic body L with q elements, and ei is a predefined exponent; 

5 - the exponent ei is of the form l+q^^ + + in which the exponents 6i 

are predefined integers. 

Another subject of the invention is a data recording medium, characterized in that it 
comprises instructions for executing a traceable method of the invention, when these 
instructions are perfomied by a decoder. 
10 A further subject of the invention is a data recording medium, characterized in that it 

comprises instructions for executing a traceable method of the invention, when said 
instructions are performed by a transmitter. 

A further subject of the invention is a traceable encryption and/or decryption system 
for broadcast data capable of enabling the identification of a traitor, among different lawful 
15 users, who has communicated secret data to a third non-authorized party enabling this third 
party to encrypt and/or decrypt broadcast data, this system comprising: 

- a transmitter able to encrypt broadcast data, this transmitter being able to implement 
at least one first secret cryptographic function, and 

- several decoders able to decrypt the broadcast data, all the decoders being capable of 
20 implementing at least one same secret cryptographic function identical to said first function 

or its inverse, each decoder for this purpose being equipped with a memory in which a 

mathematical description of said second function is recorded; 

characterized in that the memory of each decoder contains a mathematical description 

of said second function different from the one recorded in the memory of the other decoders 
25 or in the memory of the other groups of decoders, so that this mathematical description 

exclusively identifies the particular decoder or group of decoders among all the decoders. 

Finally, a further subject of the invention is a memory intended to be associated with a 

decoder of a traceable encryption and/or decryption system according to the invention, 

characterized in that it comprises a mathematical description equivalent to said second secret 
30 function able to be used by the decoder, this mathematical description consisting of several 

elementary functions (Gij) each one equal to the composite of at least three functions as per 

one of the following equations: 
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Gij = f ogq (1) oS 

G2j = f'2oOgq(2)Ofl,j 



a-l,j = f'r-loOg^(r-l)Ofr.2J 
5 aj = TOg,j«OfMJ 

in which: 

- Gy is the -th elementary function of decoder j, j being the index identifying a 
decoder or group of decoders, 

10 - functions fy and f 'ij are predefined functions able to render the elementary 

functions Gij non-commutative between each other, 

- Oj is a permutation of all indices {1; rjunique to each decoder or group of 
decoders, 

- goj(t) is the crj(t) -Ih funcdon of a predefined whole formed of r non-linear predefined 
15 functions gi commutative between each other, and 

- S and T are predefined functions able to render difficult the cryptanalysis of the 
elementary functions Gy and Gq respectively, 

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWING(S) 

The invention will be belter understood on reading the following description, given 
20 solely as an example and made with reference to the drawings in which: 

- figure 1 is a schematic illustration of the architecture of a traceable cryptographic 
system according to the invention, and 

- figure 2 is a flow chart of the traitor tracing method of the invention. 

25 DETAILED DESCRIPTION OF THE INVENTION. 

Figure 1 shows a traceable cryptographic system, generally designated 2. This system 
2 comprises a transmitter 4 of encrypted data, a data transmission network 6 and decoders 
able to decrypt encrypted data broadcast by the transmitter 4 through the network 6. The 
system 2 comprises N decoders, N being an integer greater than 100, 1000 or more. Here, to 

30 simplify the illustration, only one decoder 8 is shown. The other decoders, not shown, are 
identical for example to decoder 8. In the remainder of the description, this decoder 8 is 
associated with the index j. 
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By way of example, the transmitter 4 is a transmitter of paying television channels. 
This transmitter 4 comprises a module 10 for encrypting a content Ba and a module 12 for 
calculating a control word CWa- Content Ba is here formed of a succession of data bits 
representing the television channels in clear, i.e. not encrypted. 
5 Module 12 is able to execute a cryptographic function defined by a mathematical 

description Fk. This cryptographic function is intended to directly process a header EBa 
coded over n characters to convert it into a control word CWa also coded over n characters, n 
being a strictly positive integer greater than 100 for example. Here, by way of example, each 
character is eitlier a "0" or a "1". 

10 For this purpose, the transmitter 4 is associated with a memory 14 in which the 

mathematical description Fk of the cryptographic function is recorded. A mathematical 
description is a set of data determining the exact sequence of mathematical operations to be 
conducted in order to calculate, for every input value, the corresponding output value of this 
function, without any value other than the input value of the function having to be provided 

15 to the programme to conduct the calculations. This description Fk is recorded in the memory 
14 in a format which can be directly used by the transmitter so that module 12 is able, on the 
basis of this description, to perform its cryptographic function. Here, for example the 
description Fk is a sequence of instructions forming a computer programme. However, in the 
remainder of this description, the mathematical descriptions of the functions will be solely 

20 shown in the forms of mathematical relations expressed using conventional symbols. The 
computer programme or programmes coiTcsponding to the mathematical relations described 
below are easy to write. 

The description Fk will be described in more detail with respect to figure 2. 

Module 10 is able to execute an encryption function E parametered by the control 

25 word CWa constructed by module 12 in order to encrypt content Ba and to output a 
corresponding encrypted content CBa- The encryption function E here is a conventional 
invertible encryption function. It is for example an AES encryption function (Advanced 
Encryption Standard) or the encryption algorithm known under the name "one time pad". 

For each content Ba encrypted by module 10 using the control word CWa, the 

30 transmitter 4 is able to broadcast a data pair towards all the decoders in the system. This data 
pair is formed by the header EBa and the encrypted content CBa- 
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To decrypt the data transmitted or broadcast by the transmitter 4 through the network 
6, the decoder 8 comprises a calculation module 20 to calculate the control word CWa and a 
decryption module 22 to decrypt the encrypted content CBa- 

Module 20 is able to execute a cryptographic function. This function is defined by a 
5 mathematical description Fkj different from description Fk. More precisely, this description 
Fkj is different from all the descriptions Fkj used in the other decoders of the system 2. 
However, even though the mathematical description Fkj is different from description Fk, the 
function it defines is the same. Consequently, the conversion of the header EBa by module 20 
makes it possible to obtain the control word CWa, i e- the same as the one which would have 
10 been obtained using module 12. Under these conditions, the description Fkj is said to be 
equivalent to description Fk- 

Similarly to transmitter 4, the decoder 8 is associated with a memory 21 in which the 
mathematical description Fkj is recorded. 

The description Fkj will be described in more detail with respect to figure 2. 
15 Module 22 is able to execute a decryption function D. This function D is the inverse 

of function R making it possible to decrypt content CBa using the control word CWa 
constructed by module 20 on the basis of the received header EBa. 

The decoder 8 is also able to transmit the content Ba decrypted by module 22 to a 
television set 26 on which it is displayed in clear. 
20 The transmitter 4 and each of the decoders are based on conventional programmable 

calculators able to execute instructions recorded on a data recording medium. For this 
purpose, the memories 14 and 21, in addition to the secret parameters for encrypting and 
decrypting transmitted data, contain instructions for execution of the method in figure 2. 

The functioning of the system 2 will now be described with reference to the method 
25 of figure 2. 

The method in figure 2 is divided into three main phases. A set-up phase 50 of system 
2, a use phase 52 of system 2 and finally a search phase 54 to search a traitor among the 
different lawful users of the system 2. 

Phase 50 starts with a construction step 60 to construct the mathematical description 
30 Fk. For this purpose, r non-linear functions gi are constructed during an operation 62, r being 



a strictly positive integer. The number r of functions gi is chosen so as to verify the following 

relationship: 

(1) N<r! 

in which N is the number of decoders in system 2. 
5 These functions gi are constructed so as to be commutative between each other, 

through the composition operation, so that the following relationship is verified: 

(2) VUe{l,...,r},j^l g, og, = g, og, 

in which the symbol o represents the composition operation of two mathematical 
functions. 

10 Here, each of these functions is a non-linear function converting a tuple into another 

tuple. By tuple is meant here a set of n elements. For example the set of n coefficients of a 

polynomial of degree (n-1) may be considered a tuple. 

I'liererore, each function gi takes n input variables and outputs n calculated variables. 

Here they each correspond to a system of n non-linear equations with n variables, n is a 
15 strictly positive integer which here corresponds to the number of characters of the header 

EBa. 

Here, each function gi is chosen to form an encryption block Gi of a multivariate 
encryption algorithm, when it is composed on the right and left with linear functions. An 
example of multivariate encryption algorithm is for example the C* algorithm proposed by 

20 Matsumoto and Imai in Tsuloniu MalsunUo and Hideki Imai, "Public Quadratic Polynomial- 
tuples for Efficient Signature Verification and Message Encryption, Advances in 
Cryptology" - EUROCRYPT '88 (Cristoph G. Giinther, e d), Lecture Notes in Computer 
Science, vol. 330, Springer, 1988, pp. 419-453). Other examples of multivariate encryption 
algorithms are the algorithms known under the names SPLASH v2 (NESSIE project, New 

25 European Schemes for Signatures, Integrity and Encryption) and HFE (PATARIN Jacques 
Hidden Fields Equations (HFE) and Isomorphisms of Polynomials (IP): two new families of 
Asymmetric Algorithms ( Eurocrypt 96, Springer Verlag, pp. 33-48). 

So as to obtain from elements gi a description that is both simple and compact of the 
resulting encryption blocks Gi, the gi functions are chosen as being monomial functions, 

30 called monomes. 

As an example, here each of the functions gi operates on the elements an extension L' 
of degree n of a base body L with q elements. For example here q = 2 and L = { 0. 1 } . 
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Extension L' is shown as the set of polynomials of form: 

%r 

in which: 

- the coefficients are elements of the body L 
5 - the index i is an integer, and 

- X is a variable. 

Extension L' is provided with the addition of polynomials and with multiplication 
modulo an irreducible polynomial of degree n defined by the following equation: 

10 in which: 

- the coefficients pi are predefined elements of body L, and 

- X is a variable, 

As an example, the gi functions are functions of extension L' in extension L' of the 
form: gi(a) = a^' 
15 in which: 

- a is an element of extension L', and 

- the exponent ei is a predefined integer of the form \+q^ + + in 
which q is the number of elements of body L and the exponents 0^ are predefined integers. 

Here d is chosen to be equal to 2 so that the exponent ei of each of the functions gi has 
20 the form l+q^\ 

The advantage of an exponent ei in this form is that if each element a of extension L' 
is identified with tuples (ao, ai, an-i) of coefficients, each of coefficients bo, bi... , bn-i of 
element b of extension L' defined by the equation b = gi (a) is written as a function of degree 
d only of coefficients a^ ai... , an-i of a. That is to say, here, as a quadratic function in the 
25 particular case when d equals 2. In this particular case, each coefficient b, may be written in 
the form of the following quadratic function: 

bi=(Co ao + . . . + c„.i a„.i) + (co,i ao ai + . . . + Co,n-i ao an-i) + (ci,2 ai ai + . . . + ci, „.i ai a„. 

l) + . . . + Cn-2,n-l an-2 an-1 

in which the n coefficients Cn and the n(n-l)/2 coefficients Cu,v are constants belonging 
30 to the body L. 
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Therefore by means of the form of chosen exponent, the mathematical description of 
each function gj is compact and can be easily recorded in a memory. 

Subsequently, during an operation 64, two functions S and T of L^^ over L^^ are chosen, 
in which L^^ is the set of tuples formed of elements of body L. Preferably, these S and T 
5 functions are linear invertible functions. 

For example the mathematical description of each of these functions S and T is a 
matrix of n elements by n elements, each of these elements belonging to body L. 

Description Fk is subsequently constructed during an operation 66, by composing 
functions gi and functions S and T in the following manner: 
10 (3) Fk = To gr o gr-io . . . ogi ogioS. 

After constructing description Fk, the method is continued by construction step 70 to 
construct the equivalent description Fkj for each decoder. 

During this step 70, for each decoder j in the system, a single permutation oj of the set 
{1,2, . . ., r} over itself is defined during an operation 72. This permutation oj is for example 
15 constructed either randomly or is deduced from index j identifying the decoder and from a 
secret parameter M. 

It is to be noted that it is possible to construct a single permutation for each decoder in 
the system since equation (1) is verified. 

Subsequently, during an operation 74, r-1 bijections fy are chosen for user j. Each of 
20 these bijections fy is a invertible function of the L^^ assembly on itself. These bijections fy are 
for example described using a matrix of n elements by n elements, each of these elements 
belonging to body L. 

For example, during this operation 74, the bijections fij are drawn randomly from the 
set of invertible linear applications of the L^^ set in itself. Another possibility is to deduce each 
25 of these bijections fij from the index j of the decoder and from the secret parameter M. 

Finally, during an operation 76, the mathematical description Fkj is constructed. For 

this purpose, r elementary functions Gij are constructed for decoder j. These functions Gij 
are constructed by composing the functions S, T, fy and gi as follows; 
(4) Gij = og^j (1) oS 
30 G2j= /-],og,j(2)Ofi,j 

a.i,j= og,j(,.i)Of,.2j 
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GrJ = TOg„j(,)Uj 

in which: 

- f \ j is the inverse of bijection fy, and 

- goj(t) is function gi wliose index i is equal to the permute of index t by permutation 
5 oj of user j, t belonging to the set {1,2, . . ., r}. 

The property of function gi according to which each coefficient bi of element b of 
extension L' defined by the equation b = gi(a) may be written as a polynomial of degree d 
only, is conserved when function g, is composed on the right and left by bijections or linear 
functions. Tlierefore, the components of element y of L" defined by the equation y=Gij (x) 
10 may be described by a polynomial of degree d only of the components Xi of element x of L''. 
For example when d equals 2, the component yi is defined using the following mathematical 
description: 

yi=(c'o Xo + . . . + C'n-l Xn-l) + (c'o.l Xq Xi + . . . + C'o,n-l Xq Xn-l) + (c' 1,2 X] X2 + . . . + C' i, „-! 
Xi Xn-l) + ... +C'n-2,n-l Xn-2 Xn-l 

15 in which the n coefficients c'u and the n (n-l)/2 coefficients c'u^v are constants 

belonging to body L. 

Therefore by means of the choice of exponent ei in the form 1 +q ®\ the mathematical 
description of each elementary function Gy is simple and compact and hence takes up litde 
memory space. In particular, in the embodiment described here, the mathematical description 

20 of each elementary function Gij is a system of n non-linear equations with n variables. 

The description Fkj is formed by these r elementary functions Gy. By processing the 
input message with the equation (5): Fkj= Grj o Gr-i,j o . . .oGij oGi j, exactly the same output 
message is obtained as the one which would have been obtained using description Fr. The 
equivalence of the mathematical descriptions Fkj and Fk is easy to verify by replacing, in the 

25 preceding equation, each elementary function Gy by its definition given by equation (4). By 
so doing in the previous equation, we obtain: 

FKj = To g^j(r)Ogq(r.i)0. . .Og^j(2) Ogq(i) OS 

Since all the gi functions are commutative between each other, it is therefore shown 
that description Fkj is equivalent to description Fk. 
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It is therefore understood that the function of the bijections fij is to make the 
elementary functions Gij non-commutative between each other. In this case, to obtain an 
equivalent description to description Fk, the elementary functions Gy can only be composed 
with one another in the increasing order of their index i as in equation (5). 
5 In addition, the sturdiness of the system against any attempted cryptanalysis, in the 

particular embodiment described herein, is based on the difficulty of the isomorphisms of 
polynomials, also known as the IP problem. With knowledge of the Gi j functions, it is 
mathematically very difficult , even with knowledge of all the functions gi to gr, to identify 
the values since unknown functions are used in each elementary function Gij for their 

10 camouflaging by composing on the right and left. Here, these unknown functions are 
functions S and T which are kept secret and the bijections fy. AiVhereupon it is not possible 
for an unlawful user possessing a set of valid elementary functions Gij to construct a new set 
of elementary functions G'ij in which the order relationship defined by cij between the gi 
functions is not maintained. In other words, since the unlawful user is incapable of finding 

15 functions S, T and fy from the elementary functions Gy said user must be content with 
modifying the mathematical description of each elementary function Gy without being able 
however to modify the order in which these elementary functions must he combined. 
Therefore since the order in which the elementary functions G'y are combined is not 
modified, the order in which the functions gi are combined is not modified either. The 

20 advantage of this property will become apparent on reading the remainder of the description. 

Once the elementary functions Gy have been constructed for each user j of system 2, 
they are distributed and recorded, during step 80, in the memory 21 of each decoder 8 in the 
form of a computer programme for example. 

Also, during this step 80 the infomiation necessary for executing traitor search phase 

25 54 is recorded in memory 14 for example. In particular, all the functions used to construct 
each elementary function Gy are recorded in this memory 14 and each of the permutations ctj 
used. The relationship between each permutation oj and the decoder for which it has been 
used is recorded. Similarly a relationship enabling identification of a user from the identity of 
the decoder is recorded in this memory 14. 
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Once functions Gy have been recorded in the memory of each decoder 8, the use 
phase 52 of system 2 can be initiated. 

During this phase 52, the transmitter 4 randomly draws a new header EBa during step 
84 at regular intervals, for example every second. 
5 This header EBa is converted during step 86 by module 12 using description Fk in 

order to obtain the control word CWa. 

Content Ba is tlien encrypted by module 10 during a step 88 using function E and the 
control word CWa. The encrypted content CBa and the header EBa used for this purpose are 
then broadcast conjointly, during step 90, by transmitter 4 through the network 6 towards all 
10 the decoders within system 2. 

On receipt of the encrypted data, each decoder firstly proceeds during step 92 with 
calculating the control word CWa from the received header EBg. During this step, the module 
20 successively uses, and in order, each of the elementary functions Gij recorded in its 
memory 21, so as to perform the calculation corresponding to the composite of the 
15 elementary functions Gy in accordance with equation (5). 

After this step 92, the module 20 outputs the same control word CWa as the one 
constructed by module 12 of transmitter 4. 

Using this control word CWa and function D, the module 22 during step 94 decrypts 
the received encrypted content CBa. The decrypted content Ba delivered by module 22 is then 
20 transmitted for in-clear display to a television set 26 for example. 

Steps 84 to 94 are repeated throughout the entire use phase of system 2 for each data 
item or data frame broadcast by transmitter 4. 

For the remainder of the description, it is assumed that the user of decoder j has 
transmitted to an unlawful user his set of elementary functions Gij so that this unlawful user 
25 is able to use a pirate decoder to decrypt the data broadcast by the transmitter 4 without 
having to pay a subscription for example. The user of decoder j is therefore the traitor since 
he has illegally and unlawfully transmitted secret data allowing decryption of data broadcast 
by transmitter 4. 

Traitor search phase 54 starts by capturing and analysing, during step 100, a pirate 
30 decoder of the unlawful user. During this step 100, analysis of the decoder is made so as to 
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detect therein the elementary functions Gy unlawfully communicated to it by the traitor, and 
the order in which these functions Gy are combined to convert the received header EBa into a 
control word CWa. 

The elementary functions found in the pirate decoder are here noted Gi,p in which the 
5 index i indicates the order in which these elementary functions are used to convert the control 
word EBa. 

Subsequently each function Gi p is analyzed during step 102 to find the function gi on 
the basis of which it was constructed. Said analysis is possible for example for the operator of 
system 2 since the operator knows the functions S, T fy and gi used to construct the 

10 elementary functions Gij of each user of the system. 

Therefore after step 102, the operator of the system 2 is capable of saying that the 
elementary function Gi,p was constructed from function gm, that the elementary function G2,p 
was constructed from function gn and so on for each of the functions Gi,p in which the indices 
m and n of functions gm and gn represent the index of the function gi used to construct Gi,p 

15 and G2,p respeclivcly. 

On the basis of this information, the operator is therefore able, during step 104, to 
reconstruct the permutation oj used during the construction of the elementary functions Gi,p 
used in the pirate decoder. Once this permutation oj is reconstructed, it is compared during 
step 106 with different permutations recorded in memory 14 during step 80. 

20 By means of the above the traitor, i.e. the user of decoder j, is identified since in 

system 2 each permutation o] corresponds to a single decoder itself associated with a single 
user. 

This system and this method therefore prove to be particularly dissuasive to prevent 
lawful users from communicating the necessary data for decrypting encrypted contents CBa. 

25 Studies of the sturdiness of the method in figure 2 against attempted cryptanalysis 

have been conducted. These studies have shown in particular that the system and the method 
of figure 2 resist against attacks led by a coalition of k traitors, k being a positive integer 
greater than two. By coalition of k traitors is meant here a group of k lawful users who 
attempt, by pooling their respective sets of elementary functions Gij, to construct a new 

30 equivalent description of function Fk. It was shown that these unlawful users are able at the 
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most to construct a function using one or more new sets of elementary functions Gi p from 
these k sets of elementary functions Giy However any new set of elementary functions Gi,p 
results from the combination of successive sequences of elementary functions Gjj extracted 
from each of the sets of elementary functions at its disposal. For example for a coalition of 
5 two traitors, the new set of elementary functions Gi,p which an unlawful user could construct 
would be composed of the p first elementary functions {Gi,i, G2,i, Gpj} of the first 
traitor and of the r-p last elementary functions (Gp^i^i, Gr,2} of the second traitor. To 
combat said attempted camouflaging of the traitor's identity, the number r of functions gi is 
chosen to be sufficiently high so that at least one traitor can be identified solely on the basis 

10 of the identification during phase 54 of only part of the permutation Oj used to construct his 
set of elementary functions Gij. For example, for a coalition of two traitors, r is chosen to be 
sufficiently high so that at least one of the traitors can be identified either on the basis of the 
p first elementary functions Gjj or on the basis of the r-p last elementary functions Gi,2. 

It will be noted in the above method that the same secret data, i.e. the cryptographic 

15 functions associated with descriptions Fk, Fkj are used to encrypt and decrypt so that the 
described encryption method has the same characteristics as an algorithm of symmetric 
encryption. In particular, by means of this property, the method described here is quicker 
than an algorithm of asymmetric encryption. 

Here the functions S, T, fij must be kept secret, whilst the functions gi are optionally 

20 published. 

In system 2, only one same function for calculating the control word CWa is used both 
in the transmitter 4 and in the decoders. Therefore this cryptographic function does not need 
to be invertible which facilitates the choice and construction of functions gj. However, as a 

variant, the description Fk coiTesponds to an encryption function and descriptions Fkj 
25 correspond to the inverse of this encryption function. In this variant, the different descriptions 
Fkj implanted in the different decoders of the system are equivalent to one another and are 
descriptions equivalent to the inverse of the function defined by description Fk- The 
previously described construction of descriptions Fkj applies, the only difference being that 
functions gi must be invertible in this variant. In this case the description Fk is for example 
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used to encrypt content Bg directly, whilst the equivalent descriptions Fkj are used to decrypt 
encrypted contents CBa directly. 

Here the cryptographic function corresponding to descriptions Fk and Fkj converts an 
initial message coded over n characters into a converted message also coded over the same 
5 number of characters. This cryptographic functions does not increase the size of the 
converted message with respect to the size of the initial message, contrary to the finding with 
asymmetric algorithms for example. As a variant, the cryptographic function increases the 
size of the converted message with respect to the size of the initial message. It will be noted 
however that in this variant this increase in size remains independent from the number of 
10 traitors. 

System 2 has been described in the particular case in which a description I'kj is 
associated with a single decoder. As a variant, one same description Fkj is associated with a 
group of decoders. In this variant, all the decoders of system 2 are grouped together in several 
groups so that the description Fkj identifies not a particular decoder but the group to which 
1 5 this particular decoder belongs. 
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